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i A method for the recording and retrieval of 
information relevant to the activities of the user. 
The invention may be employed to provide a 
memory prosthesis in the form of a highly port- 
able device (30) (e.g. a device worn like a watch) 
which records all kinds of information about the 
user's life, and provides a simple and rapid 
means of access to that information. The device 
receives and stores information from external 
sources ('objects') via, for example, a cellular 
communications network, or from signal 
generators identifying specific machines, 
places, or people carrying other ones of the 
same type of device. Events comprising en- 
counters between 'objects' are recorded auto- 
matically, being time-stamped and stored 
chronologically, and a rapid search method for 
such a database is disclosed. The data can 
either be stored in the memory of the device 
itself, or, for better protection against failure, in 
a central data repository of the system, with a 
fail-safe backup. 
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This inv ntion relates to a system and method for th recording and retrieval of information relevant to the 
activities of th user. The invention is particularly suitable for implementati n in the form of a memory aid device 
which is portable, and preferably wearable by the user. 

Memory problems are widespread but little has been done to exploit information technology to help. People 
have many procedures designed to compensate for their fallible memory, for example, writing lists, organising 
things in files, putting notices on notice boards and setting alarms. Even in a well-organised setting, things 
might be mislaid or forgotten because they were not seen to be important at the time they were encountered. 
These failures of memory have a cost, both in the time spent recovering (such as looking for mislaid docu- 
ments) and in the time spent organising things in the first place so that problems do not anse. 

One current form of memory aid is the electronic personal organiser, which is similar in form to a hand- 
held calculator. Although such a device is capable of holding large amounts of information, each item must be 
entered usually manually, so the user must both input the information and remember to do so. 

Various other systems have recently been proposed to help the user recall past events as well as to provide 
reminders of future intentions. For example, in EP-A-0.495,622 there is described an activity-based informa- 
tion retrieval system which automatically captures and records certain aspects of the context in which a re- 
corded event took place. The system relies on a variety of apparatuses for monitoring, recording and time- 
stamping various key aspects of human activity, from which a readable list of episodes, or activity diary' can 
be generated automatically. In one example, the system uses encoded identifiers, each intended to be carried 
by people working in the environment being monitored. One particularly convenient form of identifier is the 
-active badge" offered by Olivetti. This identifier takes the form of miniaturised circuitry in a housing able to 
be pinned or clipped to the clothing of the person to whom the identifier is issued. The circuitry is designed to 
emit pulse width modulated infra-red coded signals for a tenth of a second every 12 to 1 5 seconds. The signals, 
by their nature, have a range of about six metres, and will not travel through walls, which makes them very 
useful for keeping track of people moving between rooms in a normal working environment In each of the 
rooms or corridors of interest would be positioned one or more sensors responsive to the infra-red signals. 
The sensors would be connected to a master station processor, which would have the task of polling the sensors 
for identification 'sightings'; processing the data (which would include decoding the signals to determine which 
person was within range of a specified sensor at the time of polling), and presenting the processed data .n a 
visual format in the form of a diary. This diary, which correlates quite closely with human recollections of past 
episodes can be used simply to stimulate further recall, or to identify an episode and its time of occurrence, 
or to show a set of episodes from different sets. The time may be used to locate the corresponding items in 
any other set of time-stamped data, such as a sequence of video frames or an audio record of a meeting. 

A related system was disclosed in an article in The Sunday Times, 11 February 1 990. entitled ■Computers 
acquire social skills", by Jane Bird. This mentioned the use of identity buttons to enable the computer to know 
who was where in the building at all times. Associated with the system is a network of microphones and/or 
video cameras capable of recording conversations. It gave the example of a copier in a room monitored by the 
computer. Upon the copier's developing a fault, a frustrated would-be user tries to recall what a colleague told 
him about how to cure the fault. The computer is interrogated to find the last time that the two people concerned 
were at the copier. Once this particular bit of information has been recovered, it is used to access the time- 
stamped audio records of what was said in the room containing the copier at that point of time. In this way. the 
enquirer has the opportunity of hearing again the conversation between him and his colleague. 

The aforementioned systems have several practical limitations. These include the need on the part of the 
user to devote a lot of effort to identifying a particular time and place from the raw data, and the lack of precise 
episode definition from such data. Also the systems capture just the location of users, and not their activity or 
45 other significant episodes. These drawbacks would make the systems of relatively little practical value. 

There is still therefore, a need for an improved memory aid system which requires minimum input from 
a user, and yet which is easier to use for retrieving information than to remember orf ind whatever it is that has 
been forgotten or mislaid. It is an object of the present invention to meet this need. 

According to the present invention, there is provided an information recording system comprising: 
so a plurality of objects, each object representing a human user or other entity identifiable by the system 

and each object comprising an agent, means for communicating between the agent and the agents of other 
ones of the objects, and, in communication with the agent, at least one of a database, a sensor, and a user 

interface; ' • . 

th system including at least on databas ; at least one sensor, and at least on us r interface; 
55 at I ast part of the agent of at least on of th objects representing a human user being portable by th 

user providing interaction with the us r, and identifying to the system th location of th user, 

the information comprising, for a given object, a chronological sequence of time-stamped facts in its 
database, each fact comprising an attribut and a value of that attribut for a given object at the time indicated 
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by the time stamp; and 

th facts being automatically recorded in the database on the occurrence of physical or logical coll ca- 
tions of two or more of the objects. 

According to another aspect of the invention, there is provided a method of searching a database in which 
5 data is organised as a set of threads, each thread comprising a chronological sequence of time-stamped facts 
all of which relate to a single object and at least some of which also represent descriptors of other objects, 
each object representing a person or an identifiable entity, and each of the facts comprising an attribute and 
a value of that attribute for a given object, the method including displaying the sequence of facts of a selected : 
thread, or the sequence of events defined by the coincidence of two or more threads, and moving selectively 
10 forward or backward in time through the displayed sequence of facts or events, and the method including ena- 
bling the selection, for subsequent display, of any one of the threads of a displayed event . .; , 

The invention also provides an apparatus for recording facts relevant to the activities of, the user of the 
apparatus, including a database, a user interface, and means for receiving signals from external sources, the 
signals representing facts related to the sources; each of the facts being timerstamped and comprising an at- 
15 tribute and a value of that attribute for a given source at the time indicated by the time t stamp> and the facts 
being automatically recorded in a chronological sequence in .the .database, on the occurrence of physical or 
logical collocations of the apparatus and one or more of the sources; and the apparatus being operable through 
the user interface to enable the user to retrieve from the database a sequence of occurrences of a selected 
fact or pattern of facts. ; 
20 Preferably, the apparatus of the preceding paragraph include means to enable manual entry of the facts 

or other information into the database, and is wearable by the user. 

The invention may be employed to provide a memory prosthesis in the form of a highly portable device 
(e.g. a device worn like a watch) which records all kinds of information about the user's fife, and provides a 
simple and rapid means of access to that information. The device receives and stores information from external 
25 sources ('objects') via, for example, a cellular communications network, or from signal generators identifying . 
specific machines, places, or people carrying other ones of the same type of device. The data can either be 
stored in the memory of the device itself, or, for better protection against failure, in a central data repository 
of the system, with a fail-safe backup. 

Data is gathered continuously with no attempt being made to categorise or filter it at the time of collection. 
30 This means that all the data is retained, so that items that might have been categorised as insignificant at the 
time of collection can later be retrieved. As a result there will be large quantities of data for the user to search. 
For the memory prosthesis to be usable, it must provide a mechanism for enabling the user to constrain the 
search and rapidly find the relevant information. This mechanism is supported by the data model described 
below. ~ 
35 The data consists of series of events which happen to each object in the system. Each object has its own 

"thread", a linear organisation in time of the events occurring as the object encounters other objects. Access 
to the data is achieved by displaying sequentially, running either forwards or backwards in time, the series of 
events along a selected thread. Rapid searching is made possible by specifying events formed by the coinci- 
dence of several threads, or by changing from one thread to another at a event where the two threads intersect 
40 . The memory prosthesis records all kinds of information about the user's life, and by providing a simple 
and rapid means of access to this information it can help the user to recall things that might otherwise be for- 
gotten. All information in certain specified categories is gathered, without filtering, so that even things that 
might not have appeared important at the time of recording can later be recovered. 

A system and method in accordance with the invention will now be described, by way of example, with 
45 reference to the accompanying drawings, in which:- 

Fig. 1 is a diagrammatic representation of the elements which comprise an 'objecf, as defined herein; 
Fig. 2 is a pictorial representation of an example of a system in accordance with the invention; 
Fig. 3 is a diagrammatic representation of the threads of several objects. 

Fig 4 illustrates a set of 'threads' to show how a user can navigate the information in a database; . 
so Fig 5 shows an example of a user interface; and , 

Fig. 6 is a flow chart showing how data is processed by one of the 'objects* used in the system of the in- 
vention. 

Referring to Fig. 1, the basis of the information recording system comprises at least two 'objects' 10 of the 
kind shown, which tog ther define a domain. Th d main may cov r, for example, a room, a building, all the 
55 buildings within a group of buildings, or a larger ar a. An obj ct 10 represents a person r another identifiable 
ntity such as a location, an apparatus or machine, a vehicl , a. piece of mail, some t xt, a number, a tim . 
The system thus comprises a set of objects 1 0, within the.d main, for which a history can be generated auto- 
matically. Each object 10 conforms t the architecture shown in Figure 1. All objects 10 have a database 12 
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in which th y stor descripti ns of the activities in which they were involved. A whiteboard might store th 
names of people using itd rived f r xample f rom activ badg identifiers, and snapshots of its contents at 
periodic intervals. Associated with each object is an agent 14 which has three main functions: it manages the 
database 12- it exchanges information with other objects over a communications channel 16; it communicates 
with human users over a user interface 18 (Ul) to answer queries using the database; f irtally, it collects data 
from its own sensors 20. While all objects 10 have an agent 14, a database 12, and a means 16 to communicate 
with other objects, they may not possess a Ul if they do not provide an interface for querying their database. 
A room-conversation detection object is an example. Some objects 10 may not contain sensors if they obtain 
all their information f rom remote sources over the communications channel. 

Referring now to Figure 2, there is shown a system containing a number of objects which form a domain 
including a personal, portable, computer 30 which may be described as a 'tab'. This tab includes an agent, a 
database a Ul which includes a screen 32 and control buttons 34, and communication means which are pre- 
ferably wireless, such as radio or infra.red. Jane, the person whom the tab represents, carries or wears the 
tab as she moves around the domain and carries out various tasks. The tab here is the object which represents 
Jane. When she encounters (e.g. approaches, enters, or uses) one of the other objects, a signal between 
Jane's tab and the other object generates a time-stamped record in the database of Jane's tab (and possibly 
also in the database of the other object), the record includes the time of the encounter (the time^sfamp), and 
identifies the primary object (Jane), an attribute of that object (e.g. location - 'af ), and a value of that attribute 

By^ySZmp\e t let us assume that Jane enters her off ice one day at 10:15. Here, the record in her database 
will show "10:15 (time-stamp) - Jane (object) - at (attribute) - Jane's Office (value of attribute)-. The screen 
on her tab can use either woras or icons to display this record, or a mixture of the two. If Steve enters Jane's 
office at 10-47, a record is generated to show that Steve and Jane are collocated in Jane's office. When Jane 
uses the telephone at 10:53 to call Bob, the object representing her has the attribute 'using' and the value 'tel- 
ephone' The record will show Jane, Steve, and telephone being used by Jane (to call Bob), in Jane's off.ce. 
Jane makes a note during the telephone call. This note may also be recorded in Jane's database, either auto- 
matically if she made it, say, on a workstation which is another of the objects in the system, or manually using 
her tab. Jane then finishes the telephone call, and Steve leaves her off ice. 

If many months later, and using the example just described, Jane wishes to recall the note she made dunng 
her telephone conversation, she can ask her tab to show her a list of all her telephone calls. This might be un- 
manageably long, so she might remember that she made the note while on the telephone at a time when Steve 
was in her office. Thus she could ask her tab to list for her all those occasions when she was using the telephone 
while Steve was in her office. This would considerably limit the search (assuming Steve was an infrequent 
visitor), and the tab screen would show just those (few) occasions which would include the one that Jane was 
seeking She could then identify the note, for example by its time-stamp, and display it on her tab.. 

The objects shown in Figure 2 have different configurations and requirements. It is most likely that all the 
human users will need a database and a Ul, but much less likely that the other objects, like off ices or machines, 
will need them. However, it fe sometimes useful for machines to have both, so that records of who used which 
machine at what time can be kept and later reviewed. 
40 The following definitions and explanations are provided to assist in understanding the invention. 

DATA MODEL 

Information is held in the database as a sequence of time-stamped facts. 
45 Each fact consists of an object, an attribute and a value. 

A fact represents the knowledge that the attribute of the object is the value. 
The time-stamp indicates the time at which this fact became known. 
The sequence is held in chronological order in a relational database. 

An object represents either a person or any other entity which is identifiable by the system, such as a lo- 
50 cation, an apparatus or machine, a vehicle, a piece of mail, some text, a number, or a time. 

An attribute indicates one of the possible properties that some object may possess, such as hair colour, 
whereabouts, or size. . . - ^ 

A value represents the particular value of an attribute, such as black for hair colour, the kitchen for where- 
abouts, or larg for siz . (See Table 1 below). 

55 " • ' " ' ' ' 
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Tim 


Object 


Attribute 


Value 


11:05:26 Mon 21st June 1993 


Steve. 


at 


Kitchen 


1 1 :37: 1 3 Mon 21 st June 1 993 


Jane 


at 


Jane's Office 


11:39:22 Mon 21st June 1993 


Jane 


at 


Kitchen 


11:42:35 Mon 21st June 1993 


Jane 


at • ... 


Jane's Office" . 


12:01:04 Mon 21st June 1993 - 


Jane 


availability 


Busy 


12:01:09 Mon 21st June 1993 


Kitchen s 


temperature 


22 Celcius 


Table 1, Typical tim& stamped facts in a database. . 



The episode which Table 1 represents can be described as follows. Steve enters the kitchen at 11 :05. Jane 
enters her off ice at 11:37, and then goes into the kitchen at 11:39. She returns to her office at 11:42, and is 
recorded as being 'bus/ (e.g. with a telephone call) at 12:01 : Since ho change has been noted in Steve's 'at* at- 
tribute, it can be assumed that he remained in the kitchen throughout this period of time. It is possible to infer 
from this that while Jane was in the kitchen, Steve and Jane were collocated at 11 :39. This inferred fact is shown 
in Table 2. \ 1 . 

INFERENCE 

An agent may apply inference rules to the information thus held, in order to establish other facts not directly 
recorded, such as when' two people were in the same room, or the duration of a meeting. 

Such inferred /acfs may be determined by the agent upon request, or determined in advance and held in 
the database on the same footing as ordinary facts. 

Inferred facts may be used during inference, to produce further inferred facts. (See Table d below). 



35 



Time . 


Object 


Attribute - 


Value 


11:05:26 Mon 21st June 1993 


Steve 


at . 


Kitchen 


11:37:13 Mon 21st June 1993 


Jane 


at 


Jane's Office 


11:39:22 Mon 21st June 1993 


Jane 


ar 


Kitchen 


11:39:22 Mon 21st June 1993 


Steve 


co-located 


Jane 


11:42:35 Mon 21st June 1993 


Jane 


at 


Jane's Office 


12:01 :04 Mori 21st June 1993 


Jane ; 


availability 


Busy 


12:01:09 Mon 21st June 1993 


Kitchen 


temperature 


22 Celcius 


Table 2. An extra inferred fact introduced, in italics 



PATTERNS 

When a request for information is made.to the agent;, a pattern may be specified. 
so A pattern consists of either a conjunction of patterns;, a disjunction of patterns; a negation of a pattern; 

or an object. - 

Such a pattern filters the information yielded by the agent to include only those facts which conform to 
the pattern. ■ : ^ - . 

A fact conforms to a conjunction of patt rns if it conforms to each f the conjoined patterns individually. 
55 A fact conforms to a disjunction of patterns if it conforms t any on or more of the disjoin d patterns. 

A fact conforms to a negated patt rn if it does not conform to th patt rn which is negated. 
A fact conforms to an object pattern, if the fact menti ns the object of the pattern. 

5 
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SEARCH 

In response to information request, the agent searches for particular facts by considering the whole of the 
sequence of facts and making those inferences possible, to find facts conforming to the supplied pattern. 

In principle, the agent checks every fact, simple or inferred, for conformity with the pattern. 

In practice, the agent need only consider those facts pertinent to the pattern - that is, the contents of the 
pattern may be used to inform and constrain the possibly huge search undertaken by the agent to reasonable 
dimensions. . - ; ' 

For example, a pattern which specified that a particular person, pjace and day of the week must be men- 
tioned,, allows the agent to consider only those facts and inferred facts.pertinent to that person, place and day, 
thus greatly reducing the scope of the required database search and the, number of facts which must be tested 
for conformity to the pattern. 

THREADS 

If a pattern contains at least one object then the only facts that the agent will yield are those pertinent to 
that object Such a chronological sequence of facts may be considered a biography of the specif i^d object, or 
thread. 

Asimple user-interface paradigm would be to keep at least one object in the pattern at all times, and display 
a thread for that object Such a thread will mention other objects, such as locations or other people. One of 
these other objects may be selected by the user as the new focus, and the pattern used from then on would 
contain the new object Thus a switch in perspective occurs, to the thread of the newly selected object - the 
biography displayed is now that of the new object 

The world is thus seen as consisting of a variety of objects, each one of which automatically generates 
an autobiography recording events in its "life-. These objects could in principle be anything, but typical exam- 
ples are people (at least, computers attached to them), off ices, telephones, notebooks and workstations (see 
Figure 2). The autobiography for each object consists of a series of events that happened to that object, each 
event being an encounter of this object with another. These events are organised linearly in time as a "thread". 
For example, as Steve walks around his thread 40 shows him in his office 42, then the stairwell 44, and then 
the common room 46 (see Figure 3). Conversely, his office thread 42 shows him 40 enter, stay for a while and 
then leave. The stairwell thread 44 shows him 40 enter and leave and finally the common room thread 46 shows 
him arrive. A further thread 48 belonging to Jane shows her visiting Steve 40 whilst he is in his office 42. This 
visit also appears on Steve's own thread 40 and that of his office 42. During this period Steve interacts several 
times with his electronic notebook 50. Each interaction appears on the thread of the notebook 50 and also on 
Steve's thread 40 and the thread for the room in which he is using the notebook. Whilst he is in the common 
room 46, Steve uses the copier 52. This interaction also appears on his thread 40, and those of the common 
room 46 and copier 52. 

Threads that run together indicate collocation of the objects that own the threads. The collocation could 
also be taken to mean some other sort of relationship such as 'interacted with" (e.g. via telephone or worksta- 
tion), thus representing a logical collocation rather than a physical one. The significant points recorded on a 
thread are the points where threads join together or split apart, indicating a transition from one state of affairs 
to another. 

Users can retrieve information about events in their life by finding the relevant points in the threads struc- 
ture. Starting from any point they can navigate around this structure by moving forward or back between 
events along a particular thread. For example, if Steve had mislaid some papers given to him by Jane during 
her visit to his office he couid prompt his memory by looking pri his thread and f inding Jane's departure from 
his office. From here he couid move along the thread to see the subsequent events: him leaving his office, 
entering and leaving the stairwell and entering the common room. He then sees that the next event on his thread 
records him using the copier and this reminds him that he left the papers on the table beside the copier. 

The user can also switch onto another thread at a point where the current thread intersects it For example, 
if Steve found someone's originals in the copier whence came to use it he could switch from his thread to that 
of the copier. By following back down, the copier thread he could find the previous person who used the copier 
and hence return the originals. 

These examples have been very simple, but in r ality there will be a large number of ev nts in any thread 
that is to be navigated. To simplify navigation the user can specify which particular events are of interest by 
giving a patt rn to b matched. Such patterns can specify any combination of location, people, time or other 
objects- For example, if Steve specifies "in my office with my n tebook with Jane* he will see only those oc- 
casions that match this patt rn i.e. those occasions when he was in his office with Jan and made some notes. 
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The actual notes, which may have been recorded in the database by the user, are link d to thes vents, thus 
allowing him t retrieve them. 

By way of example of a user 'navigating* the database using the threads model, reference is made to Figure 
4 in conjunction with Table 3. Figure 4 shows a sequence of seven events, labelled in chronological order of 
their occurrence from 1 to 7. Each event comprises the conjunction (intersection) of two or more of threads A, 
B, and C. Event 1 shows a coincidence of threads A, B and C, event 2 involves only threads A and B, event 3 
involves threads A and C, and so on. In searching the part of the database involving these events, the user 
might 'browse' in the manner represented by way of example in Table 3. In the first step, he starts at event 1 , 
moves forward (in time) along thread A and arrives at event 2. In step 2 he moves backwards along thread A 
and returns to event 1. In step 3 he changes to thread B. In step 4 he moves forward along thread B to arrive, 
on thread B, at event 2. In step 5 he moves forward along thread B to arrive at event 4. In step 6 he changes 
to thread C. In step 7 he moves forward along thread C to arrive at event 6. 

Instead of navigating along single threads, as just described, the user may select patterns of threads, the 
simplest pattern being a conjunction of two or more threads. I step 10, search is requested by the conjunction 
of threads A, B and C. Starting at event 1, which is the first such conjunction, the user moves forward to event 
7, which is the next such conjunction. In step 11, a change is made to a pattern consisting of the conjunction 
of threads A arid B: In step 12, the user moves backwards through such patterns, the next occurrence of an 
A,B conjunction (going backwards) being event 5. 



Step No. 


Event 


Search Direction 


• - Thread 


Result 


1 


1 


Forward. . 


A 


2 (on A) 


2 


2 


Backward 


A 


1(onA) 


3 


1 


Change to B 


A 


1 (on B) 


4 


1 


Forward ' 


B 


2 (on B) 


5 . 


2 


Forward 


B 


4(onB) 


6 


4 


Change to C 


B 


4 (on C) 


7 


4 


Forward 


. C 


6 (on C) 












10 


1 


Forward 


A, B, C 


7 (on A, B, C) 


11 


7 


Change to A,B 


A, B, C 


7 (on A, B) 


12 


7 


Backward 


,, A, B. 


5 (on A,B) 


Table 3, Example of navigating data in a threads model 
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Figure 5 gives one simple, example of how the user interface might be organised for the memory prosthesis. 
The physical buttons on the side of the device can be used for moving forward or back through the current 
thread. Touching one of the on-screen buttons associated with intersecting threads switches to that thread. 

The device shown in Figure 5, in the form of a 'tab', can be large enough for. words to be used on its screen. 
However, if a smaller device, such as one in the same form as a watch, will need to have its information dis- 
played in a highly codified fashion. I this case, each episode or event listed occupies a single line containing 
a sequence of icons. The first item in each line represents' the start time of the episode. It is followed by an 
activity indicator, representing the type of activity, such as a meeting, a time spent doing paperwork, or per- 
haps a vacation. The rest of the line contains a sequence of icons, each of which represents an object which 
the user encountered in the displayed episode. The top liri 4 ' f such a display contains information which applies 
to th whole of the history. It includes an icon representing the own r of the history display d. It also includes 
the icons representing the fill r pattern. The rest of the line contains the list of it ms that ar common to all 
the pisodes listed below it. This avoids repeating icons in each episode descripti n, ther by economising on 
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scr n space. 

In reality any such user interface would be generally us d as part of some ther application, in a similar 
way to the Finder dialogues on the Macintosh. It would provide a standardised way for the user to locate in- 
formation using biographical information. The particular application would dictate what happened to the infor- 
5 mation retrieved. 

Referring now to Figure 6, there is shown a flow diagram illustrating the interactions of the main constit- 
uents of one of the objects which form part of the system of the invention. 

10 Claims *- : 

1. Information recording system comprising: 

a plurality of objects, each object representing a human user or other entity identifiable by the sys- 
tem and each object comprising an agent, means for communicating between the agent and the agents 
15 of other ones of the objects, and , in communication with the agent at least one of a database, a sensor, 

and a user interface; 

the system including at least one database, at least one sensor, and at least one user interface; 

at least part of the agent of at least one of the objects representing a human user being portable 
by the user, providing interaction with the user, and identifying to the system the location of the user; 
20 the information comprising, for a given object, a chronological sequence of time-stamped facts in 

its database, each fact comprising an attribute and a value of that attribute for a given object at the time 
indicated by the time stamp; and 

the facts being automatically recorded in the database on the occurrence of physical or logical col- 
locations of two or more of the objects. 

2. The system of claim 1 including means to enable manual entry of the facts or other information into the 
database. 

3. The system of claim 1 or claim 2 further including means for automatically recording facts in the database 
30 at predetermined times. 

4. The system of any one of claims 1 to 3 further including means for automatically recording facts in the 
database on the occurrence of predetermined values of an attribute. 

5. A method of searching a database in which data is organised as a set of threads, each thread comprising 
35 a chronological sequence of time-stamped facts all of which relate to a single object and at least some 

of which also represent descriptors of other objects, each object representing a person or an identifiable 
entity, and each of the facts comprising an attribute and a value of that attribute for a given object, the 
method including displaying the sequence of facts of a selected thread, or the sequence of events defined 
by the coincidence of two or more threads, and moving selectively forward or backward in time through 
40 the displayed sequence of facts or events, and the method including enabling the selection, for subse- 

quent display, of any one of the threads of a displayed event 

6. . An apparatus for recording facts relevant to the activities of the user of the apparatus, including a data- 
base, a user interface, and means for receiving signals from external sources, the signals representing 

45 facts related to the sources; each of the facts being time- stamped and comprising an attribute and a value 

of that attribute for a given source at the time indicated by the time stamp, and the facts being automat- 
ically recorded in a chronological sequence in the database on the occurrence of physical or logical col- 
locations of the apparatus and one or more of the sources; and the apparatus being operable through 
the user interface to enable the user to retrieve from the database a sequence of occurrences of a selected 

50 fact or pattern of facts. 

7. The apparatus of claim 6 including means to enable manual entry of the facts or other information into 
the database. 

55 8. The apparatus of claim 6 or claim 7 wherein the user interface enables th user to search by displaying 
s quentially the occurrences of a s lect d fact or pattern. 

9. The apparatus of any one of claims 6 to 8 wher in each sequ nee of occurr nces of a fact comprises 

8 
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a 'thread', wh r in each of th facts is represented by the coincidence of two or more of th threads, and 
wher in the user can search the database by selecting one thread, or by sel cting the coincidence f a 
plurality of threads, or by moving from one thread to another. 

10. The apparatus of any one of claims 6 to 9 wherein the apparatus is wearable by the user. 

11. A system comprising the apparatus of any one of claims 6 to. 10 and a plurality of the sources arranged 
to cooperate with the apparatus. 

12. The system of claim 11 including a plurality of said apparatuses, at least some of the apparatuses com-, 
prising at least some of said sources. 

1 3. The system of claim 1 1 or claim 12 wherein at least some of the sources comprise a cellular communica- 
tions network, enabling a device to determine its position in the network. 

*5 14. The system of any one of claims 11 to 13 wherein 1 the, or each, apparatus is in communication with a cen- 
tral data processing unit 



10 



20 



25 



30 



35 



15. .A system comprising:. ... - . 

a plurality of signal sources; each signal source providing signals that identify the signal source; 
a first one of the signal sources being portable so thatthe first signal source can be locatednear a second 
one of the signal sources; the first signal source: providing signals that indicate location of the first signal 
source. 

signal receiving circuitry for receiving signals from the signal sources and for providing signal data 
indicating information from the signals; upon receiving a signal from the first signal source indicating that 
the first signal source is located near the second signal source, the signal receiving circuitry providing 
collocation signal data indicating that the first signal source is located near the second signal source; 

memory for storing data; and 
processing circuitry connected for receiving signal data from the signal receiving circuitry and also con- 
nected for accessing the memory; ~ 

upon receiving signal data indicating a signal from one of the signal sources, the processing cir- 
cuitry using the signal data to obtain event data, the event data indicating the signal source and a time 
at which the signal data were received; 

upon receiving the collocation signal data, the processing circuitry using the collocation signal data 
to obtain collocation event data, the collocation event data indicating the first signal source, the second 
. signal source, and the time at which the co-location signal data were received. 
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chronologically, and a rapid search method for 
such a database is disclosed. The data can 
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